#   Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import unittest

import numpy as np

import paddle
import paddle.fluid as fluid
import paddle.fluid.core as core

paddle.enable_static()


class TestGcdAPI(unittest.TestCase):
    def setUp(self):
        self.x_np = 12
        self.y_np = 20
        self.x_shape = [1]
        self.y_shape = [1]

    def test_static_graph(self):
        startup_program = fluid.Program()
        train_program = fluid.Program()
        with fluid.program_guard(startup_program, train_program):
            x = fluid.data(name='input1', dtype='int32', shape=self.x_shape)
            y = fluid.data(name='input2', dtype='int32', shape=self.y_shape)
            out = paddle.gcd(x, y)

            place = (
                fluid.CUDAPlace(0)
                if core.is_compiled_with_cuda()
                else fluid.CPUPlace()
            )
            exe = fluid.Executor(place)
            res = exe.run(
                fluid.default_main_program(),
                feed={'input1': self.x_np, 'input2': self.y_np},
                fetch_list=[out],
            )
            self.assertTrue(
                (np.array(res[0]) == np.gcd(self.x_np, self.y_np)).all()
            )

    def test_dygraph(self):
        paddle.disable_static()
        x = paddle.to_tensor(self.x_np)
        y = paddle.to_tensor(self.y_np)
        result = paddle.gcd(x, y)
        np.testing.assert_allclose(
            np.gcd(self.x_np, self.y_np), result.numpy(), rtol=1e-05
        )

        paddle.enable_static()


class TestGcdAPI2(TestGcdAPI):
    def setUp(self):
        self.x_np = np.arange(6).astype(np.int32)
        self.y_np = np.array([20]).astype(np.int32)
        self.x_shape = [6]
        self.y_shape = [1]


class TestGcdAPI3(TestGcdAPI):
    def setUp(self):
        self.x_np = 0
        self.y_np = 20
        self.x_shape = [1]
        self.y_shape = [1]


class TestGcdAPI4(TestGcdAPI):
    def setUp(self):
        self.x_np = 0
        self.y_np = 0
        self.x_shape = [1]
        self.y_shape = [1]


class TestGcdAPI5(TestGcdAPI):
    def setUp(self):
        self.x_np = 12
        self.y_np = -20
        self.x_shape = [1]
        self.y_shape = [1]
